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(54) A method and apparatus for visualization of database search results 



(57) A method and apparatus for representing the re- 
sults of a search of a database. The present invention 
provides for creating a view of database search results 
via a tree structure in which detail is selected and context 
preserved. In the present invention, the tree structure 
(Fig.2a) is created (402) based on user specified param- 
eters. These parameters represent attributes of docu- 
ments stored in the database and may differ from the 
search parameters. The tree structure is then mapped 
(404) to a static reference surface which Is visually per- 
ceived as three-dimensional. The reference surface is 
comprised of a detail area where detail of the tree struc- 
ture (Fig. 2b) is displayed and a context area for display- 
ing other portions of the tree in less detail but which con- 
veys to the viewer a sense of context. The tree structure 
may be scrolled about the reference surface to bring por- 
tions of the structure into a direct detail view while retain- 
ing a context view of the overall tree. 
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Description 



The present invention relates generally to the field 
of information display, and in particular to providing a vis- 
ual display relating to the results of a database search 
It IS well understood that information visualizations 
provide insights to the underlying data. For example for 
any given set of information, new information regarding 
pattems or relationships can be obtained by looking at 
attributes Of the infomiation. It is often useful to view the 
attnbutes of the information in a hierarchical structure 
However, a difficulty lies in displaying large hierarchical 
structures in a limited display area. 

EP-A-435,601 discloses a technique for displayina 
and manipulating three-dimensional representations of 
a tree structure which have rotating substructures 

US-A-4, 752.889 describes a graphic display that 
shows links between chunks of knowledge The user 
With mouse Clicks, can obtain a display of links from a 
displayed chunk of knowledge to other chunks of knowl- 
edge which are added to the display Screen scrolling 
mechanisms allow movement from one area of the over- 
all graph to another 

EP-^A-535,986 describes a method for centering a 
selected node of a node link structure along a center^g 
nne. The nodes are in rows, and each row extends 
across a centering line with links between nodes in ad- 
jacent rows. When a user requests a centering operatk,n 
for an indicated node, a sequence of images is present 
ed, each including a row that appears to be a continua- 
tion o the row with the indicated node and that includes 
a continued indicated node that appears to be a contin- 
uation of the indicated node. 

Furnas, G.W., "Generalized Fisheye Views," CHI '86 
Proceedings, ACM, April 1986, pp. 1 6-23. describes fish- 
eye views that provide a balance of local detail and global 
context. Section 1 discusses fisheye lenses that show 

wShT^^ " "^'^'^ ""^'^^ ^^°^*"9 'he Whole 
world, showing remote regions in successively lessde- 

iTm n ?^i"o " °* '"^ "New Yorker-s View 

of the United States." Section 3 describes a degree of 
interest (DOI) function that assigns to each pofn^fn a 
structure a number telling how interested the user is in 
seeing that point, given the current task. A display can 
then be made by showing the most interesting points as 
indicated by the DOI function. The fisheye view ^an 
achieve, for example, a logarithmically compressed dis- 
play of a tree, as illustrated by Fig. 4 of Furnas for a tree 
structured text file. Section 4 also describes fisheye 
views for botanical taxonomies, legal codes, text out 
lines, a decisions tree, a telephone area code directorv 

Section 5 indicates that a display-relevant notion of a pri- 
on importance can be defined for lists, trees, acylic di- 
rected graphs, general graphs, and Euclidean spaces 
unhkethe geographical example which inspired the met- 
aphor of the "New Yorker's V^w." the underlying st7uc- 
turesneed not be spatial, nor need the outputbe graphic. 



Fig. 6 of Furnas shows a fisheye calendar 

EP-A-447.095 discloses a processor which 
presents a sequence of images of a workspace that is 

stretchedtoenabletheusertoviewapartofaworkspace 
in greater detail. The workspace includes a middle sec- 
tion and two peripheral sections that meet the middle 
section on opposite edges. Each of the sections appears 
to be a rectangular two-dimensional surface and they are 
perceptible in three dimensions. When the user is view- 
10 ing the middle section as if it were parallel to the display 
screen surface, each peripheral section appears to ex 
tend away from the user at an angle from the edge of the 
middle section so that the peripheral sections occupy rel- 

'5 stretching, the middle section is stretched and the pe- 
ripheral sections are compressed to accommodate The 
stretehing. When the user requests destretching. the 

middle section isdestretchedandthe peripheral seciions 
are decompressed accordingly 

The present invention seeks to provide for the or- 
ganization and visualization of database search results 
independent of the search parameters. Often, it is desir- 
ab e o obtain properties of the search results independ- 
2S Th ! 1 ^^^''^^ P^^^'^^'e^s ^or example, a search on 
a database rnay be performed by specifying the authors 
» may be undesirable to limit the search by specifying a 
date. It niay laterbe desirable to organize the search re- 
sults by date ,n order to detemiine when particular doc- 
uments were created. 

30 "The present inventbn provides a method for gener- 
ating hierarchically related information for the results of 
a query to a database, said database for storing docu- 
ments, said method comprising the steps of 
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a) executing a search on a database to obtain a set 
of documents; 

b) receiving a set of N ordered user specified view 
preferences, each of said user specified view pref- 
erences defining a property of information stored in 
said database; 

c) generating an N + 1 level tree structure based on 
said set of documents and said set of N ordered user 
specified view preferences; 

d) displaying a reference surface on which said tree 
structure is displayed, said reference surface having 
a first area for showing a first portion of the tree struc- 
ture in detail and a second area for showing second 
portions of said tree structure lacking detail; 

e) detennining a layout of said tree structure relative 
to said reference surface; 

f) mapping said tree structure to said reference sur- 
fece based on said layout to create tree display data; 
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g) displaying said tree structure on said reference 
surface. 

The invention further provides a computer controlled 
display system according to claim 5 of the appended s 
claims. 

In the present invention, a tree structure is created 
based on the search results and user specified parame- 
ters. The user specified parameters represent attributes 
of documents stored in the database and may differ from 
the search parameters. The tree structure is then 
mapped to a static reference surface which is visually 
perceived as three-dimensional. The reference surface 
is comprised of a detail area where detail of the tree 
structure is displayed and a context area for displaying 
other portions of the tree in less detail but which conveys 
to the viewer a sense of context. The tree structure may 
be scrolled about the reference surface to bring portions 
of the structure into a direct detail view while retaining a 
context view of the overall tree. 

Figure 1 is a block diagram of computer controlled 
display system in the currently preferred embodiment of 
the present invention. 

Figure 2a illustrates a tree structure laid out on a 
plane. 

Figure 2b illustrates the tree structure of Figure 2a 
which has been mapped to a reference surface of a pre- 
ferred embodiment of the present invention. 

Figure 3a illustrates a reference surface which is 
perceived as three-dimensional as is utilized in a pre- 
ferred embodiment of the present invention. 

Figure 3b is a side view of the reference surface of 
Figure 3a with respect to a user viewpoint. 

Figure 4 is a flowchart of the general steps per- 
formed when creating the visualization in a tree structure 
in a preferred embodiment of the present invention. 

Figure 5 is an example of a tree structure showing 
the results of a database search organized based on 
user specified preferences. 

Figure 6 is a flowchart of user interactions that may 
be performed in a preferred embodiment of the present 
invention. 

Figure 7 is a flowchart of the steps performed for 
generating the visualization of a tree structure in a pre- 
ferred embodiment of the present invention. 

Figure 8 is a flowchart of the steps for creation of the 
tree structure in a preferred embodiment of the present 
invention. 

Figure 9 is a flowchart of the steps for laying out a 
tree structure onto a plane in a preferred embodiment of 
the present invention. 

Figure 1 0 is a flowchart of the steps for scrolling the 
tree structure about the reference surface as may be per- 
formed in a preferred embodiment of the present inven- 
tion. 

Figure 11 illustrates a data structure for a node in a 
preferred embodiment of the present invention. 

Figure 12 a screen display of a tree view of the re- 



sults of a database search in a preferred embodiment of 
the present invention. 

Figure 13 is a screen display showing a highlighted 
path, in a preferred embodiment of the present invention. 

Figure 14 is a screen display showing a highlighted 
path after it has been scrolled into view, in a preferred 
embodiment of the present invention. 

A method and apparatus for visualization of the re- 
sults of a database search is described herein. In the fol- 
lowing description numerous specific details are set 
forth, such as data models for representing a tree struc- 
ture, in order to provide a thorough understanding of the 
present invention. It would be apparent, however, to one 
skilled in the art to practice the invention without such 
specific details. In other instances, specific implementa- 
tion details such as the system calls for causing a tree 
structure to be displayed on a screen, have not been 
shown in detail in order not to unnecessarily obscure the 
present invention. 

Hierarchically related information is often represent- 
ed as a tree. As used herein, the term node will refer to 
a point on the tree structure. Each node includes pointers 
to a parent node, a child node and a sibling node to cre- 
ate the tree structure. A root node is the highest level 
node. Leaf nodes are the bottom level nodes. 

When a tree structure becomes large, it may b© dif- 
ficult to present the entire tree on a display area in full 
detail. Thus, it may be difficult to trace that path of a node. 
Further, it is often desirable to know where a particular 
node in a tree structure is located in order to understand 
the context of the data. The present invention addresses 
this by providing a three-dimensbnal context view of the 
tree which can be scrolled. 

It should be noted that a tree is in the general class 
of node-link structures. As will become apparent in the 
description below, the present invention could be imple- 
mented so as to support other node link structures. 

Various techniques are known in the art for render- 
ing three-dimensional images on two dimensional dis- 
play screens. However, manipulating three-dimensional 
images is computationaly intensive. Often, expensive 
3-D graphics hardware is used in order to render images 
in an acceptable timeframe. The present invention 
avoids the need for using sophisticated hardware to pro- 
vide a three dimensional visualization which can be ma- 
nipulated. In the present invention, a three dimensional 
reference surface is created, about which the information 
moves. This provides for seeing the entire composition 
or path to the end nodes of a tree structure. 

As will become apparent in the description below, a 
preferred embodiment of the present invention provides 
visualizations of the results of a database search (often, 
important infomnation can be determined by examining 
relationships between the various search results.) How- 
ever, it would be apparent to one of skill in the art to apply 
the present invention to other hierarchically structured 
information. 
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.Overview of a Computer Cnntr^n^ d Display Syc.», 
the Currently Preferred Fmh^Hi ^ent of tho pLo ~ 
Invention 



Ovon^iewo f the Tree \/isuall2atlnn 



Referring to Figure 1, the computer based system 
on which the currently preferred embodiment of the 
present invention may be implemented Is comprised of 
a plurality of components coupled via a bus 1 01 The bus 
101 may consist of a plurality of parallel buses (e q ad- 
dress, data and status buses) as well as a hierarchy of 
buses (e.g. a processor bus. a local bus and an I/O bus) 
In any event, the computer system Is further comprised 
of a processor 102 for executing instructions provided 
via bus 101 from Internal memory 103 (note that the In- 
ternal memory 103 is typically a combination of Random 
Access and Read Only Memories), The processor 102 
will be used to perform various operations in support of 
creating the tree visualizations. Such operations that 
would be performed by the processor 102 are described 
with reference to Figures 6-10. The processor 102 and 
Internal memory 103 may be discrete components or a 
single integrated device such as an Application Specifi- 
cation Integrated Circuit (ASIC) chip. 

Also coupled to the bus 1 01 are a keyboard 1 04 for 
entering alphanumeric input, external storage 105 for 
storing data, a cursor control device 106formanipulatinq 
a cuisor, and a display 107 for displaying visual output 
The keyboard 1 04 would typically be a standard QWER- 
TY keyboard but may also be telephone like keypad The 
external storage 105 may be fixed or removable mag- 
netic or optical disk drive. The cursor control device 106 
e.g. a mouse or trackball, will typically have a button or 
switch associated with itto which the performance of cer- 
tain functions can be programmed. 

The currently preferred embodiment of the present 
invention is designedfor use on a commercially available 
IBM compatible computer system available from various 
vendors, and which is running the Microsoft Windows 3 1 
Operating System. The Windows operating system pro- 
vides for the use of multiple workspaces concurrently. 
The operation of Windows-like operating systems is well 
known in the art. 

In operation, the currently preferred embodiment of 
the present invention will also make use ol various user 
interface facilities. The cursor control device is used to 
position a cursor located on the display to a desired lo- 
cation (i.e. -point" to the desired location). When the cur- 
sor control devtee is positioned (i.e. pointing) to some- 
thing on a display, the button associated with the cursor 
control device may be depressed and released in order 
o invoke an action. This is referred to as a "click" A dif- 
ferent function may be invoked if the button is depressed 
and released twice in succession. This is referred to as 
a double dick." When a user points to an object on the 
display, depresses the button and holds it down the ob- 
ject will follow the cursor and be placed at the location 
on the display where the button is released This is re- 
ferred to as a "drag and drop" or "drag- operation 



Figures 2a and 2b illustrate the visualization of a tree 
structure in the currently preferred embodiment. Figure 
2a illustrates a tree structure 201 which is projected onto 
a plane 202. Referring to Figure 2b, the same tree struc- 

ono "^^^ "'^PP^'' 3 reference surface 

203. The reference surface 203 has a center panel 204 

10 ^" ^ P^"®' and a bottom panel 

206. Thecenterpanel204hasarectangularshapewhile 
the top panel 205 and bottom panel 206 have trapezoidal 
shapes. 

Although not illustrated, the reference surface may 
be rotated by 180 degrees. This may be done if it is de- 
sirable to have a vertical representation of a tree struc- 
ture. Further, the various levels of the tree structure of 
Figures 2a and 2b are aligned in columns. As will be- 
come apparent in the description below, such an align- 
ment reduces processing computatkjns for scrolling of 
the tree structure across the reference surface and does 
not effect the underlying nature of the tree structure 
However, it would be apparent to one of skill in the art to 
practice the present invention with a tree structure where 
the various levels are not vertically aligned in columns 

The reference surface provides visual cues so that 
the visualizaton is perceived as three dimensional Fig- 
ures 3a and 3b Illustrate the reference surface in greater 
detail. Figure 3a illustrates a reference surface as dis- 
played. The reference surface 300 is comprised of a 

t?^"^' • ^ P^"^' and a bottom panel 
303. The top panel 302 is perceived as folded back from 
center panel 301 at fold edge 304. The bottom panel 303 
IS perceived as folded back from center panel 301 at fold 
edge 305. In order to provide visual cues as to three-di- 
3s mensions (i.e. it is folded back) the top panel 302 and 
bottom panel 303 have different fill patterns than center 
panel 301 . Further, the background of the reference sur- 
face may also be shaded to provide the three-dimension- 
al visual effect. 

40 '^'9"fe 3b is a side view of the reference surface 300 
with respect to user viewpoint 306. From Figure 3b it is 
readily observed that the user viewpoint 306 is orthMo- 
nal to center panel 301 . whereas information on top pan- 
el 302 and bottom panel 303 are not. Accoitiingly. infor- 
mation in top panel 302 or bottom panel 303 are viewed 
in perspective. 

It should further be noted that the size of the display 
area for the reference surface may change. In the cur- 
rently preferred embodiment when the width of the dis- 
pby area changes, all the panel widths correspondinqly 
change. However, if there is a change to the height of 
the display area, only the center panel will change height 
This IS done to show the maximum number of nodes in 
detail while retaining context. And as will be described 
in greater detail below, it negates the need to update 
took-up tables used in creating the three-dimensional ef- 
fect of the tree structure. 

Figure 4 is a flowchart describing the general steps 
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performed for the rendering of the present invention's 
visualization of a tree structure. First, perspective trans- 
fomnation look-up tables for the top and bottom panels 
are created, step 401 . These look-up tables are for cre- 
ating the display data for portions of the tree structure on s 
the top and bottom panels. The look-up tables are static 
for the durations of the visualization. In a preferred em- 
bodiment, each look-up table stores 3000 sample points 
for transforming an orthogonal view to a perspective 
view. Values between the sample points are obtained 
through interpolation. Techniques for creating such a 
look-up table to create a perspective view are well known 
in the art. Thus, further description on the generation of 
sample points in the look-up table is not deemed neces- 
sary. Next, the tree structure (i.e. the node/link pointer 15 
data) is created or otherwise obtained, step 402. Crea- 
tion of the tree structure is dependent on what the struc- 
ture represents. In a preferred embodiment, a hierarchi- 
cal view of the results of a database search are embod- 
ied in the tree structure. A description of the creation of 
the tree structure in a preferred embodiment is provided 
below. Once the tree structure is created or obtained, it 
is mapped to the reference surface by the following 
steps. First, the tree structure is laid out on a two dimen- 
sional plane, step 403. Initial layout of the tree structure 2S 
will center the tree on the reference surface. Subsequent 
layouts, e.g. as an effect of scrolling, will cause the layout 
positions to move. In the laying out step, each node will 
obtain a planar address. The tree is then rendered onto 
the reference surface, step 404. This is accomplished by 30 
transforming the plane coordinates for the nodes to 
screen coordinates using the look-up tables generated 
in step 401 for nodes in the top and bottom panels and 
direct scaling for nodes in the center panel. 

When the visualization is presented to a user, the 35 
reference surface is displayed and the tree structure 
overlaid. The user invocation of and processing for 
scrolling of the tree structure is described in greater detail 
below. 

The rendering of the visualization is less computa- 40 
tionaly intensive because of the assumptions that the us- 
er's point of view is constant, i.e. orthogonal to the center 
panel and that the top and bottom panels are symmetric. 
However, it retains the benefit of a three-dimensional 
representation of viewing both context and detail concur- 
rently. 

The present invention is now described in reference 
to a preferred embodiment of viewing the results of a da- 
tabase search. However, it would be apparent to one of 
skilled in the art that the visualization of the present in- so 
vention could be used for viewing any information capa- 
ble of representation in a tree structure. 

Information Visualization of Database Search Results 

55 

In a preferred embodiment of the present invention, 
a database maintains a collection of documents. Each 
document has multiple indices by which it can be refer- 



enced. The present invention allows the results of a da- 
tabase search to be organized and viewed In a manner 
based on these indices. The indices used for organiza- 
tion and viewing may be different from the indices used 
for the database search. The indices which a user spec- 
ifies by which they would like to view the search results 
are termed preferences. 

The preferences that a user specifies are ordered. 
A first preference is used to create the top level of the 
tree structure, a second preference the second level, and 
so on until the bottom level of the structure which are 
representations of the individual items of the search re- 
sults (i.e. the documents.) Typically, the tree structure 
created from the search results will be shallow (the 
number of specified preferences plus 1) and broad (the 
number of documents in the search result.) A label on 
each node will indicate the corresponding value for the 
preference. Figure 5 illustrates an example of a view of 
a search result. In this view, a first preference is Authors, 
a second preference is Type and a third preference is 
Date. Referring to Figure 5, a top level 500 identifies 
three authors^ Allen (node 501), Bowers (node 502) and 
Card (node 503). Following the Allen branch, in the sec- 
ond level of the hierarchy. Type, a grouping 504 of doc- 
ument types Is specified, namely Spreadsheet (node 
504a), Report (node 504b) and Memo (node 504c). From 
the third level of the hierarchy, it is observed that the 
spreadsheet is dated 6/15/93 (node 505a), the report 
dated 12/1/93 (node 505b) and the Memo on 6/30/94 
(node 505c). Finally, we see that from the bottom level 
of the hierarchy the documents associated with the Allen 
branch (nodes 506-508). 

Following the Bowers branch, it is observed from the 
second level that documents authored by Bowers are of 
type Graphics (node 509a) or Code (node 509b). The 
documents of type Graphics were dated on 1/1/93 (node 
510a) and the code on 5/15/94 (node 510b). Finally, the 
documents associated with the Bowers chain are indi- 
cated in nodes 511-514. 

Following the Card branch, it is observed from the 
second level that documents authored by Card are of 
type Audio (node 51 5a) or Image (node 51 5b). From the 
third level, the documents of type Audio are dated 
3/24/94 (node 516a) and the documents of type Image 
are dated 2/16/94 (node 5116b). Finally, the documents 
associated with the Card branch are defined by nodes 
517-519. 

In a preferred embodiment, each database that may 
be searched will have default preferences that may be 
used for viewing a tree structure. 

It is also worth noting that the preferred embodiment 
operates within the parameters of a window system. For 
example, a display view may only show a portion of a 
tree structure because the window has been sized to be 
smaller than the actual size of the window display area. 

The preferred embodiment of the present invention 
is further described with reference to the flowchart of Fig- 
ure 6. Referring to Figure 6. a user first selects a data- 
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base and performs a database search, step 601 Once 
the search is completed, the user may then specify how 
they would like to view the search results. In a preferred 
embodiment the user may view the results as a list of 
documents or in a tree structure. The user selects the s 
tree view, step 602. In the preferred embodiments, the 
various view options are represented as icons which the 
user selects by a point and click operation. Other means 
of view selection, e.g. via a pull-down menu could be 
used. Once the user selects the tree view, they must io 
specify the preferences upon which to build the tree 
structure, step 603. In a preferred embodiment, a user 
may select up to 5 preferences. The primary limitation 
being the size of a typical display It would be apparent 
toone skilled in the art toallowa fewer or greatemumber is 
of preferences. 

The tree structure for the view is then created and 
displayed based on the search results and the prefer- 
ences, step 604. The manner in which the tree structure 
IS built IS described in greater detail below. At this point 2o 
the user may highlight a document path, view a docu- 
ment or cause a document to be retreived from the da- 
tabase. It should be noted that in a preferred embodi- 
ment of the present invention, each node is capable of 
being selected by a point operation using the cursor con- 2S 
trol device. For any operation, the user first points to a 
desired node, step 605. Highlighting the document path 
through the tree structure is invoked by a single click of 
the cursor control devfce. Tlie highlighting is accom- 
plished by displaying the path in reverse video (see Fig- 30 
ure 12). Before highlighting it must be determined if the 
document node corresponding to the pointed to node is 
in the center panel, step 606. If the document node is in 
the center panel, the document path is highlighted, step 
608. If the document node is not in the center panel the 3S 
tree view is rotated (i.e. scrolled) to bring the document 
node into the center of the center panel, step 607 This 
scrolling is done automatically When completed the 
document node will be centered in the center panel and 
the path highlighted per step 608. 40 

Viewing a document, step 609. is invoked by a dou- 
ble click of the cursor control device. The viewing mech- 
anisms of a preferred embodiment provide for retrieval 
of the corresponding document and for presentation on 
a window in the display Retreiving a document for edit- 4S 
ing purposes, step 610 is accomplished through a drag 
and drop operation (into a predefined work area) Note 
that in a preferred embodiment, the node pointed to need 
not be the document node. It could be any node in the 
tree hierarchy which ultimately point to the desired doc- so 
ument. 

The creation and rendering of a tree structure in the 
currently preferred embodiment is described with refer- 
ence to the flowchart of Figure?. Referring now to Figure 
7, the underlying tree representation is created from the ss 
search results and the provided preferences, step 701 
In a preferred embodiment, the tree consists of virtual 
nodes, the inner nodes which correspond to the prefer- 



ence values, and actual nodes, the leaf nodes (displayed 
in the right-most column) which correspond to the docu- 
ments resulting from the search. In a preferred embodi- 
ment, the creation of the tree is accomplished through 
recursive calls to a software program called AddNode 
A flowchart outlining the functionality of AddNode is pro- 
vided in Figure 8. AddNode takes as input, a parent node 
and a document. In creating the tree AddNode is called 
tor each document, specifying a root node as the parent 
node. Referring now to Figure 8, the value of the prefer- 
ence, say X, for the current depth in the hierarchy is ob- 
tained, step 801. This would involve examining the da- 
tabase to determine the value of the index corresponding 
to the preference. A search is then made to determine if 
any child node has the value X, step 802. If no child node 
has the value X, then a new virtual child node having the 
value X is created, step 803. The depth of the hierarchy 
IS then incremented, step 804. A check is then made to 
determine if the maximum depth in the hierarchy has 
been reached, step 805. If it has, then an actual node is 
created whose parent Is the child with the value X (i e 
the current child), step 806. If a child having value X ex- 
ists, then AddNode is recursively called with that child as 
the new parent, step 807. 

Referring back to Figure 7. the tree structure is then 
laid out on a plane, step 702. It should first be noted that 
in a preferred embodiment each level in the hierarchy is 
in a column (which is not visible) of the display window 
The steps for laying out the tree structure on a plane are 
Illustrated in the flowchart of Figure 9. Referring to Figure 
F, the tree is traversed to count the number of nodes at 
each level in the hierarchy step 901 . Each level will form 
a column so a node count for each column is created In 
a preferred embodiment, each nodes when displayed is 
80 X 20 pixels in size. Thus, the size of a column can be 
readily determined. This will correspond to the number 
of nodes in a column. Next, a bounding rectangle for 
each column is detemnined. step 902. The bounding rec- 
tangle is based on the number of columns, the number 
of nodes in each column, and the dimenstons of the dis- 
play window The bounding rectangle will encompass all 
the nodes in a level of the hierarchy The tree is then 
traversed to place the nodes in the plane In terms of 
plane coordinates, step 903. For the placement, the x 
coordinate is determined by the nodes depth in the hier- 
archy and the number of levels in the hierarchy The y 
coordinate is determined by the node's position within 
the column as the tree structure is traversed. 

Referring back to Figure 7, the tree layout is then 
rendered on the reference surface, step 701 . This is ac- 
complished by transforming the plane coordinates to dis- 
play screen coordinates. The transfonnation that takes 
place depends on the panel. As described above the 
reference surface relates to the plane in that it merely 
folds at predetemiined vertical fold locations (i e at a 
particular Y-coordinate in the plane). So determinatron 
of which transformation to use requires examination of 
the Y-coordinate of the node. For the center panel plane 
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coordinates are scaled to the those of the reference sur- 
face. For the top and bottom panels look-up tables are 
used to apply perspective transformations on the plane 
coordinates. For each of the top and bottom panels two 
look-up tables are used. One look-up table maps plane 
y-distance from a panel fold to screen y-distance. A sec- 
ond look-up table maps plane x-distance from the center 
to screen x-distance from the center. 

As described above with respect to Figure 6, when 
a leaf node is in the top or bottom panel and the path to 
that leaf node is selected, scrolling of the tree may occur 
Figure 1 0 is a flowchart describing the steps for scrolling. 
The scrolling of a preferred embodiment is intended to 
provide animation. It has been determined that anima- 
tion aids the users perception of what is occurring. To 
accommodate animation, the scrolling occurs in anima- 
tion steps with a total animation time of 0.6 seconds 
(which has been determined to be optimal). Referring to 
Figure 10, First the distance each column of the tree will 
need to travel is determined, step 1001 . In a preferred 
embodiment the selected nodes, its ancestors and its 
children will be centered on the reference surface. The 
distance that must be traveled in each animation step so 
that the most distant column will get to Its destination is 
then determined, step 1002. This distance is based on 
the time required for recent tree renderings. This dis- 
tance will provide an offset for each column for each an- 
imation step. The animations steps are then performed, 
step 1003. Here, tree is rendered on the reference sur- 
face incrementing each column's offset towards its des- 
tination at each step until all of the columns are at their 
final destinatbns. 

Internal Representation of a Node 

Figure 11 illustrates a data structure for a node in a 
tree structure in the currently preferred embodiment of 
the present invention. The structure is comprised of a 
plurality of pointers 1101 -1104 and a layout address for 
the node, 1 1 05. The pointer 1 1 01 points to a parent node, 
the pointer 1102 points to a child node, the pointer 1103 
points to a sibling node and the pointer 1104 points to 
document information. The pointers 1101-1103 are typ- 
ical for a tree structure representation. The pointer 1104 
IS used to point to the document itself. The layout ad- 
dress 1105 contains the address for the node with re- 
spect to the plane as generated in the layout plane step 
described in Figure 9. 

Screen Displays of the Currently Preferred 
Embodiment. 

Figures 12-14 "Copyright 1 994, Xerox Corporation" 
(17 U.S.C. 401) are screen displays illustrating the infor- 
mation visualization of database search. Referring to 
Figure 12, a tree of a search result is illustrated. Here we 
see that various nodes have been rendered on the top 
and bottom panels. Figure 13 illustrates the highlighting 
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of a node along with its descendant nodes. Referring to 
Figure 13. the node 1301 is selected and highlighted. 
This results in the descendant nodes 1302-1305 to also 
be highlighted. Finally, Figure 14 illustrates a selection 
s which causes scrolling. Assuming the starting position 
as illustrated in Figure 12, node 1401 is selected. The 
descendant nodes 1402-1411 are then scrolled to the 
center panel and highlighted. Note that nodes have 
scrolled off the center panel and onto the bottom panel. 

10 

Claims 

1. A method for generating hierarchically related infor- 
ms mation for the results of a query to a database, said 

database for storing documents, said method com- 
prising the steps of: 

a) executing a search on a database to obtain 
20 a set of documents; 

b) receiving a set of N ordered user specified 
view preferences, each of said user specified 
view preferences defining a property of informa- 

25 tion stored in said database; 

c) generating an N -i- 1 level tree structure based 
on said set of documents and said set of N 
ordered user specified view preferences; 

30 

d) displaying a reference surface on which said 
tree structure is displayed, said reference sur- 
face having a first area for showing a first portion 
of the tree structure in detail and a second area 

35 for showing second portions of said tree struc- 

ture lacking detail; 

e) determining a layout of said tree structure rel- 
ative to said reference surface; 

40 

f) mapping said tree structure to said reference 
surface based on said layout to create tree dis- 
play data; and 

45 g) displaying said tree structure on said refer- 

ence surface. 

2. The method as recited in Claim 1 wherein each node 
in said N -i- 1 level of said tree structure points to a 

50 corresponding document and each of said N levels 
corresponds to one of said N ordered user specified 
view preferences. 

3. The method as recited in Claim 2 wherein said step 
55 of generating an N -i- 1 level tree structure is further 

comprised of: 

for each document at each of said 1 to N levels per- 
forming the steps of: 
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c1) retrieving a value for said document at a 
level being processed; 

c2) determining if a child node exists having said 
value; 5 

c3) if no child nodes exists, creating a new child 
node having said value and processing next 
level; and 

10 

OA) if a child exists having said value, process- 
ing next level. 

4. The method as recited in Claim 1 wherein N is less 
than or equal to 5. 75 

5. A computer controlled display system for displaying 
the results of queries to a database comprising: 

receiving means for receiving a set of docu- 
ment indicators, said set of document indicators cor- 20 
responding to the results of a database query; 

means for specifying one or more search pref- 
erences; 

means for constructing a tree structure based 
on said one or more search preferences and said 2s 
set of document indicators; 

means for generating a reference surface on 
which said tree structure is displayed, said reference 
surface having a first area for showing a first portion 
of the tree structure in detail and a second area for 30 
showing second portions of said tree structure lack- 
ing detail; 

layout generation means for generating a lay- 
out of said tree structure relative to said reference 
surface; 35 

mapping said tree structure to said reference 
surface based on said layout to create tree display 
data; and 

display means for displaying said tree struc- 
ture on said reference surface. 40 

The system as recited in Claim 5 further comprising 
of means for causing said tree structure to be 
scrolled across said reference surface. 

45 

The system as recited in Claim 5 or 6 further com- 
prising means for highlighting a document path in 
said tree structure. 

The system as recited in Claims 5, 6 or 7 further so 
comprising means for enabling viewing a document 
from said tree structure. 

The system as recited in any of Claims 5 to 8 further 
comprising means for enabling retrieval of a docu- ss 
ment for editing from said tree structure. 
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